- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.4k
Added TokenizingTextBox automation peer #3891
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added TokenizingTextBox automation peer #3891
Conversation
…ion if attempting to update value when in a readonly state
| Thanks jamesmcroft for opening a Pull Request! The reviewers will test the PR and highlight if there is any conflict or changes required. If the PR is approved we will proceed to merge the pull request 🙌 | 
| Thanks @jamesmcroft! We'll check this out with the accessibility tools. It should show up with Narrator, eh? @Kyaa-dost think you could test it out too and compare against the current store based sample app? @azchohfi I think this would be a candidate to possibly take for 7.0.1 for added value to fix some accessibility? Assuming we can close on it soon and are still waiting on the Notifications and Sample App Caching fixes? | 
| @jamesmcroft build error:  | 
…//github.com/windows-toolkit/WindowsCommunityToolkit into jamesmcroft/tokenizingtextbox-automationpeer
| 
 Apologies @michael-hawker, I copied the comments from the base implementation on that one. Should be sorted now | 
| I forgot to flag this to 7.0.1 and already kicked it off. We didn't have a tracking issue either, so forgot about that too. We'll still get it reviewed soon and merged though for whichever next release we do. | 
| 
 Sorry that was my bad. I was working through bringing more WCT control support to Legerity. I chose this one then got blocked so came to put a fix in, completely forgot to raise an item. I'll sort that out and link | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested with narrator, the behavior seems very usable, but I just have a few question.
        
          
                Microsoft.Toolkit.Uwp.UI.Controls.Input/TokenizingTextBox/TokenizingTextBoxAutomationPeer.cs
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                Microsoft.Toolkit.Uwp.UI.Controls.Input/TokenizingTextBox/TokenizingTextBoxAutomationPeer.cs
              
                Outdated
          
            Show resolved
            Hide resolved
        
      Co-authored-by: Rosario Pulella <[email protected]>
| 
 I think the suggestions were fair. The likelihood of someone using whitespace for these values is probably slim 👍 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @jamesmcroft, it's looking good!
        
          
                Microsoft.Toolkit.Uwp.UI.Controls.Input/TokenizingTextBox/TokenizingTextBoxAutomationPeer.cs
          
            Show resolved
            Hide resolved
        
      | { | ||
| [TestClass] | ||
| [TestCategory("Test_TokenizingTextBox")] | ||
| public class Test_TokenizingTextBox_AutomationPeer : VisualUITestBase | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's worth adding a test ensuring that the actual list of tokens is also being presented to UIA. Currently, we wouldn't notice if this breaks and as such leaving out crucial information to users using UIA.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Apologies for the huge delay looking into these comments. I've added the additional test for checking the children of the automation peer.
To select the items, I used the SelectAllTokensAndText method on the TokenizingTextBox but noted in the test, this will select an empty text item and append it to the collection.
| @jamesmcroft think you can address @chingucoding's comments? | 
| Thanks @jamesmcroft! @chingucoding this look good to you now? Might make sense to merge this one before your other TTB PR #4101? (though I don't think they conflict) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, thank you for adding the automation peer and making TokenizingTextBox accessible @jamesmcroft ! @michael-hawker I think we can merge this now, this shouldn't interfere with my PR (and if it does, so be it) :)
Fixes #3910
Introduce an automation peer for the
TokenizingTextBoxbased on aListViewBaseAutomationPeerwith the additionalIValueProvidercapability to return the value of the autosuggest text box.This change improves the UI automation tree hierarchy to ensure that the control and its children are nested correctly.
PR Type
What kind of change does this PR introduce?
What is the current behavior?
The
TokenizingTextBoxdoes not have an automation peer.What is the new behavior?
An automation peer has been introduced that improves the interaction of the control through UI automation tooling.
The change includes the ability to interact with the
AutoSuggestBoxelement by getting and setting the text value, and surfacing up through the automation peer.PR Checklist
Please check if your PR fulfills the following requirements:
Other information